/**
 *   SFCGAL
 *
 *   Copyright (C) 2012-2013 Oslandia <infos@oslandia.com>
 *   Copyright (C) 2012-2013 IGN (http://www.ign.fr)
 *
 *   This library is free software; you can redistribute it and/or
 *   modify it under the terms of the GNU Library General Public
 *   License as published by the Free Software Foundation; either
 *   version 2 of the License, or (at your option) any later version.
 *
 *   This library is distributed in the hope that it will be useful,
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *   Library General Public License for more details.

 *   You should have received a copy of the GNU Library General Public
 *   License along with this library; if not, see <http://www.gnu.org/licenses/>.
 */

#ifndef _SFCGAL_MULTISOLID_H_
#define _SFCGAL_MULTISOLID_H_

#include <vector>
#include <boost/assert.hpp>

#include <boost/serialization/base_object.hpp>

#include <SFCGAL/Solid.h>
#include <SFCGAL/GeometryCollection.h>

namespace SFCGAL {

/**
 * A MultiSolid
 * @ingroup public_api
 */
class SFCGAL_API MultiSolid : public GeometryCollection {
public:
    /**
     * Empty MultiSolid constructor
     */
    MultiSolid() ;
    /**
     * Copy constructor
     */
    MultiSolid( const MultiSolid& other ) ;
    /**
     * assign operator
     */
    MultiSolid& operator = ( MultiSolid other ) ;
    /**
     * destructor
     */
    virtual ~MultiSolid() ;

    //-- SFCGAL::Geometry
    virtual MultiSolid*    clone() const ;

    //-- SFCGAL::Geometry
    virtual std::string    geometryType() const ;
    //-- SFCGAL::Geometry
    virtual GeometryType   geometryTypeId() const ;

    /**
     * returns the n-th Geometry as a Solid
     */
    inline Solid&          solidN( const size_t& n ) {
        return geometryN( n ).as< Solid >() ;
    }
    /**
     * returns the n-th Geometry as a Solid
     */
    inline const Solid&    solidN( const size_t& n ) const {
        return geometryN( n ).as< Solid >() ;
    }


    //-- visitors

    //-- SFCGAL::Geometry
    virtual void accept( GeometryVisitor& visitor ) ;
    //-- SFCGAL::Geometry
    virtual void accept( ConstGeometryVisitor& visitor ) const ;

    /**
     * Serializer
     */
    template <class Archive>
    void serialize( Archive& ar, const unsigned int /*version*/ ) {
        ar& boost::serialization::base_object<GeometryCollection>( *this );

    }
protected:
    //-- SFCGAL::GeometryCollection
    virtual bool           isAllowed( Geometry const& g ) ;
};


}

#endif
